Hayden Fuller 662028619

## 1)Logic expressions

ABgtCD <= (A AND (NOT C)) OR ((NOT D) AND ((B AND (NOT C)) OR (B AND A)));
ABeqCD <= (NOT ((B OR D) AND (NOT (B AND D)))) AND (NOT ((A OR C) AND (NOT (A AND C))));

ABItCD <= (C AND (NOT A)) OR (((D AND C) AND (NOT B)) OR (((NOT A) AND (NOT B)) AND D));

```
2)VHDL
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
entity fuller_hayden_studio1 is
  Port ( A : in STD_LOGIC;
      B: in STD_LOGIC;
      C: in STD_LOGIC;
      D: in STD_LOGIC;
      ABgtCD: out STD LOGIC;
      ABeqCD : out STD_LOGIC;
      ABItCD : out STD_LOGIC);
end fuller_hayden_studio1;
architecture Behavioral of fuller_hayden_studio1 is
begin
ABgtCD <= (A AND (NOT C)) OR ((NOT D) AND ((B AND (NOT C)) OR (B AND A)));
ABeqCD <= (NOT ((B OR D) AND (NOT (B AND D)))) AND (NOT ((A OR C) AND (NOT (A AND
ABItCD <= (C AND (NOT A)) OR (((D AND C) AND (NOT B)) OR (((NOT A) AND (NOT B)) AND
D));
end Behavioral;
```

```
set_property PACKAGE_PIN W5 [get_ports CLK100MHZ]
```

set\_property IOSTANDARD LVCMOS33 [get\_ports CLK100MHZ]
 create\_clock -add -name sys\_clk\_pin -period 10.00 -waveform {0 5} [get\_ports
CLK100MHZ]

#### # Switches

set property PACKAGE PIN V17 [get ports {A}]

set\_property IOSTANDARD LVCMOS33 [get\_ports {A}]

set\_property PACKAGE\_PIN V16 [get\_ports {B}]

set\_property IOSTANDARD LVCMOS33 [get\_ports {B}]

set\_property PACKAGE\_PIN W16 [get\_ports {C}]

set\_property IOSTANDARD LVCMOS33 [get\_ports {C}]

set\_property PACKAGE\_PIN W17 [get\_ports {D}]

set\_property IOSTANDARD LVCMOS33 [get\_ports {D}]

#### # LEDs

set\_property PACKAGE\_PIN U16 [get\_ports {ABgtCD}]

set\_property IOSTANDARD LVCMOS33 [get\_ports {ABgtCD}]

set\_property PACKAGE\_PIN E19 [get\_ports {ABeqCD}]

set\_property IOSTANDARD LVCMOS33 [get\_ports {ABeqCD}]

set\_property PACKAGE\_PIN U19 [get\_ports {ABItCD}]

set\_property IOSTANDARD LVCMOS33 [get\_ports {ABItCD}]

### 4)testing

I flipped the switches in "binary order" and checked if each output was correct, which they all were.

# 5)summary

It would have been much easier to do this if we had already been introduced to SOP expressions first, though I don't know why I didn't think of doing it that way in the lab and instead went through the logic behind each with other logic gates and then converting everything to AND OR NOT